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BACKGROUND OF THE INVENTION 

[0001] This application claims priority to the provisional applications 60/223,547 

and 60/267,433, filed on August 4 ; 2000 and February 9, 2001 , respectively. Both 
of these applications are incorporated by reference in their entirety herein. 

Field of the Invention 

[0002] The present invention relates generally to computer programming 

languages and more specifically to high-level, object-oriented computer 
programming languages (used for describing the elements and structure of other 
programming languages). 

Related Art 

[0003] Developers of computer applications need to describe their programs in 

a simple, straightforward way. Often, more information needs to be expressed by 
the developer than can be expressed in programming languages such as C++ and 
Java. For many platforms, the functional structure of programs needs to be 
expressed to perform optimizations that will take advantage of the features of a 
given platform. 

[0004] Although current description languages are becoming more prevalent, they 

have limitations. For example, Microsoft® COM, an interface description 
language, primarily describes how objects interface with each other. 



[0005] COBRA, another interface description language, is also capable of 

describing only interfaces. The language lacks the ability to describe the actual 
structure of objects and blocks. Furthermore, COBRA is not extensible. Thus, 
it only allows developers to specify a fixed set of additional information. 

[0006] Therefore, what is needed is an object-oriented and descriptive 

programming language that offers a syntax that is easily extensible (i.e., allows 
new properties to be added). Furthermore, what is needed is an object-oriented, 
descriptive and extensible programming language that controls more of the 
content of the code, thus allowing the code to have greater flexibility. 

[0007] In addition, what is needed is a system in which such an obj ect description 

language can be processed in conjunction with the high-level programming 
language to be described. 



SUMMARY OF THE INVENTION 

[0008] The present invention is directed to obj ect description languages used for 

describing the elements of other programming languages, and systems used to 
effectuate the languages. The Object Description Language (ODL) of the present 
invention allows developers to describe the structure of their programs in a 
simple, straightforward manner. The language utilizes its high level description 
capabilities to realize the program in a way that retains more meta-information 
(information used to describe objects, such as fields and the type of fields) of the 
program being described. The result is that the platform on which the 
programming language of the present invention operates is able to optimize in new 
ways. 

[0009] Furthermore, the ODL of the present invention allows developers to 

perform tasks that would be impractical in other languages. In addition, the ODL 
of the present invention functions on multiple hardware and software platforms. 



[0010] The ODL of the present invention allows developers to describe the 

elements of their programs. The platform on which the language operates can 
then store the information and use it at run-time. Furthermore, the ODL of the 
present invention is extensible, and thus allows new elements to be added as 
necessary. 

[001 1 ] The system used to effectuate the language of the present invention allows 

the object description language of the present invention to work in conjunction 
with a high-level programming language in which the objects are described. For 
instance, after a code developer writes the object description language code, the 
code undergoes a special compilation which produces corresponding code in a 
high-level programming language such as C++. 



BRIEF DESCRIPTION OF THE FIGURES 



[0012] The following drawings illustrate a system in which the above-referenced 

ODL operates. The features and advantages of the present invention will become 
more apparent from the detailed description set forth below when taken in 
conjunction with the drawings in which like reference numbers indicate identical 
or functionally similar elements. Additionally, the left-most digit of a reference 
number identifies the drawing in which the reference number first appears. 

[0013] Fig. 1 is a diagram of a system that effectuates the ODL of the present 

invention. 

[0014] Fig. 2 is a block diagram showing input and output of a module in an 

example system that effectuates the ODL. 
[0015] Fig. 3 is a diagram of a header file of an example embodiment of the 

system that effectuates the ODL. 
[0016] Fig. 4 is a flowchart representing the general operational flow, according 

to an example embodiment of a system that effectuates the ODL. 



Fig. 5 is a diagram representing two example code segments of the object 
description language and corresponding C++ language according to an example 
embodiment of the present invention. 
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I. Object Description Language (ODL) 

A. ODL Overview 

[0018] The ODL of the present invention allows developers to describe their 

programs in a simple, straightforward manner. This high level description can be 
used to realize the program in a way that achieves a higher performance than 
mainstream languages. ODL can function on multiple hardware and software 
platforms. 

[0019] The ODL of the present invention is extensible. Thus, although the 

underlying platform can store information used to describe a particular program 
and use it at run-time, description of new elements can be added as necessary. 
The code of ODL is centrally generated, and thus infrastructure bug fixes and 
enhancements can occur in a single place. Furthermore, field storage and 
parameter passing mechanisms can be altered. 

[0020] Libraries, applications, and the objects contained within them can be 

expressed in the ODL. The state information in the objects can be abstractly 
expressed so that memory and data transfer can be managed using methods that 
are tuned for a particular platform. In addition, information can be provided 
through the ODL to enable other standard optimizations that are well known to 
one skilled in the pertinent art. 

[0021] The ODL, in an embodiment described herein, uses the syntax of the 

Scheme programming language because it can describe arbitrarily complex 
structures in a straight-forward manner, is easily extended with new semantics, is 
readable by humans, and is easily and quickly parsed by a computer. In addition, 
the language is supported by most text editors. In one embodiment, the ODL is 
described by the Syntax BNF supported by the Scheme programming language. 
See The Scheme Programming Language, by R. Kent Dybvig. 

[0022] It should, of course, be noted that while the present invention has been 

described in reference to illustrative embodiments, other arrangements may be 



apparent to those of ordinary skill in the art. For example, instead of using the 
above-described system with C++, another object-oriented programming language 
could be substituted. 

B. ODL Glossary 

[0023] This section describes the various entities, elements and operators of the 

Object Description Language. 

1 . Object 

[0024] An entity that contains state information, which is comprised of 

encapsulated fields of different types. Depending on the types of fields an object 
contains, it can be connected to other objects, flow between objects in a dataflow 
program, or be manipulated by a procedural program written in a high-level 
computer programming language such as C or C++. 

2. Simple Object 

[0025] An ODL simple object is an object that contains a type and is generated 

as a C++ using or typedef directive, or as a class or namespace global. The object 
does not contain any fields. If the object has a value, a class or namespace global 
is generated (depending on whether its parent is generated as a class or 
namespace). If the object has the same name as its type object, a using directive 
is used. Otherwise, a typedef directive is used. 



3. Compound Object 



[0026] An ODL compound object is an object that cannot have a type specifier. 

It contains a non-zero number of fields and/or a base object. It is generated as a 
C++ class. It cannot have a type specifier. It may or may not have child objects. 

4. Child object 

(0027] A child object is an object within an object, in a hierarchically structured 

manner. Such a hierarchical structure is illustrated below: 

(Object bar 

(object hey...) 
(object you...) 
(enum Result...) 

) 

5. Parameters 

[0028] A parameterized obj ect is one that contains a set of formal parameters that 

appear within the definition of the object. It is analogous to a C++ template. 

(object Pair 

(Parameters typel type2) 
[field obj ect 1 (type typel)] 
[field object2 (type type2)] 

) 

6. Namespace 

[0029] Some ODL objects exist for the purpose of name space only. Namespace 

, objects should be marked with the namespace property. This is illustrated by the 
following example: 



(object My Utilities (namespace) ...) 



[0030] Namespace is used in conjunction with child objects (discussed, Supra). 

To prevent ambiguity between object names, child objects are created. When the 
child objects are referred to within their parent objects, no ambiguity exists 
because they are referenced within their namespace. To refer to the object outside 
of its namespace, it must be first prefaced by the name of its parent object. 

[0031] For example, assume there are two objects by the name of "Matrix." If 

one attempts to reference the object by its name "Matrix", ambiguity results 
because it is not known to which "Matrix" one intended to refer. To solve this 
problem, each of the objects is placed within a parent object. 

[0032] In the above example, an object by the name of "Company A" could be 

created, and an object by the name of "Company B" could be created. Within 
each of these objects, a "Matrix" object would exist. As long as the child object, 
"Matrix", is referenced within its namespace, no ambiguity results. If the child 
object is referenced outside of its namespace, it must be first preferenced by the 
name of its parent (i.e.. Company A.Matrix or Company B. Matrix). 



7. C++ Abstract 



[0033] The C++ abstract property is used to indicate that an auto-generated C++ 

class is an abstract base class. In the following example, an auto-generated C++ 
class is designated as an abstract base class: 

(object foo(c++Abstract) ...) 



8. Volatile 



[0034] The volatile property is used to mark an object that is code-generated 

using normal C++ fields, rather than fields enabled for multi-buffering. In the 
following example, an object is marked with the volatile property: 



(object GraphicsContext (Volatile) ,..) 
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9. External 



[0035] The external property is used to mark an object that is code- generated by 

hand. This is illustrated by the following example: 

(Object igObject (External) .*.) 



10. Inferior 



[0036] The inferior property is used to designate an object that has no Alchemy 

meta-information associated with it. This is illustrated by the following example: 
(object igMemory (Inferior) ...) 



11. CCDoc 



[0037] The ccdoc operator is used to add documentation to an ODL object. In 

the following example, documentation is added to an object: 

(object Hello World 

(ccdoc "This object prints out V'Hello 
WorldYV) .„) 

1 2 . Enumeration 



[0038] An enumeration is a special ODL object that is equivalent to zero or more 

simple ODL objects. If an enumeration has a name, a simple ODL object is 
created with the same name, and can be used as a type. Each enumeration word 
in the names list is a simple ODL object of the type of the enum. In the following 
examples, use of enumerations are demonstrated: 

(enum(names a b c)) 

(cnum Result (names kSuccess kFailure)) 
(enum Mode (names 
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(kRead 1) 
kWrite)) 

The enum type and values can be referenced from other ODL objects and fields, 

as in the following examples: 

(enum FileMode2 (names 

(kFileRead (odlRef kRead)) 
(kFileWrite (odlRef k Write)) 
kFileAppend 

)) 

(object My result (type (odlRef Result))) 

(object Foo 
[field result 

(type (odlRef Result)) 
(value (odlRef kSuccess))] 

) 

1 3 . Construct property 

[0039] A construct property is a property of a field having a compound object 

type. If the construct property is set, the field is automatically constructed when 
the object in which the field resides is constructed. In the following example, field 
x is automatically constructed whenever the object in which it resides is 
constructed: 

[field x (type (odlRef Foo)) (construct)] 

1 4. Destruct Property 

[0040] A destruct property is a property of a field having a compound object type. 

If the destruct property is set, the field is automatically destructed when the object 
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in which the field resides is destructed. In the following example, field x is 
automatically destructed whenever the object in which it resides is destructed: 
[field x (type (odlRef Foo)) (destruct)] 

15. Override 

[0041] An override property is used to alter the default value of a field that 

inherits a value from an object in which it resides. Any of the properties of a base 
object's field can be overridden by using the override property. In the following 
example, field f, which is defined in object Base, is overridden with a new value 
of 3 in the derived object Sub: 

(Object Base 

[field f (type iglnt) (value 1)] 

) 

(Object Sub 

(base (type (odlRef Base))) 
[field f (value 3) (override)] 

) 

16. AutoSet 

[0042] The AutoSet function is used to generate set functions. If a name is 

specified, the corresponding function name will take the form setName. If no 
name is specified, the function name is computed from the field name. In the 
following example, the generation of a set function is illustrated: 
[field readMode (type igBool) (autoSet) ] 
[field gMode (type igBool) 
(autoSet graphicsMode) 



17. AutoGet 



[0043] The AutoGet function is used to generate get functions. If a name is 

specified, the corresponding function name will take the form getName. If no 
name is specified, the function name is computed from the field name. In the 
following example, the generation of get functions is illustrated: 
[field readMode (type igBool) (autoGet) ] 
[field gMode (type igBool) 
(autoGet graphicsMode) 

18. Name 

[0044] A name is used to identify both compound objects and simple objects. The 

name of an object can be specified as a normal property (as in the first example 
below) or as the first parameter of an object (as in the second example): 

(object ... (name foo) ...) 
(object foo ...) 

19. Type 

[0045] There is a finite set of built-in data types from which all objects are built. 

Alternatively, an object definition can be a type. 

20. Version 

[0046] An object's version is a number used to identify the particular version of 

the object. An object may have both major and minor version numbers. Both 
version numbers may be specified, or only the major version number may be 
specified. Major and minor version numbers are defined as follows: 
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[0047] If there is a major change to an object that would result in the object now 

being incompatible with objects with which it was previously compatible, the 
object is given a new major version number. However, if there is a minor change 
to an object that does not result in the object being incompatible with objects with 
which it was previously compatible, the object is given a new minor version 
number. 

21. Accessibility 

[0048] Accessibility of a field determines whether the field is accessible to a client 

of its object. Accessibility can be defined as public, private, or protected. Default 
accessibility is private. "Private" differs from "protected" in that a "protected" 
field can be accessed only by subclasses. A "private" field is not accessible. The 
following example illustrates how a field is defined to be of the type public: 

[field x (type iglnt) (public)] 



22. Object Element 

[0049] An object element is an entity that is part of an object. An object element 

typically has a name and holds state information of a certain type. The different 
kinds of elements are described below. 

23. Interface 

[0050] An interface element is an element used for input or output of data into or 

out of an object. 
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24. Base 

[0051] An ODL object with a base ODL object acquires all the properties of the 

object from which it originates. The following example illustrates how this is 
accomplished. 

(object FilelnputStream 

(base (type (odlRef InputStream))) 

) 

25. Field 

[0052] A field is an element inside of a compound object that holds state 

information. 

26. Persistent 

[0053] When an object's persistent property is false, all of its fields are forced to 

be non-persistent. A non-persistent field is not written or read when the object is 
written or read. Usually, an object's persistent property is set to false when fields 
are cached values and can thus be recomputed after the object is read in. 

27. Connection 

[0054] An element that serves as the conduit for the transfer of data between two 

objects. Their purpose is to establish fixed points for extensions to which they 
connect. A connection links a source of data (a field or an object output) to a 
consumer of data (an object input). They are typically used inside objects that can 
be used as bases. 
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28. Extension 

[0055] An element that defines an object to be added. The object acquires all the 

elements of the extension object and hooks its connections to the existing 
connector (place at which a connection is made to allow modular extensions 
of a program). 

29. Series 

[0056] A special kind of connection that interacts with a connector in such a 

manner as to allow the data that flows through the connector to be processed in 
multiple, independent ways. 

30. Block 

[0057] An object that has at least one input and/or output element, and thus can 

be connected to other blocks in a dataflow program. A block that contains only 
an evaluate function is referred to as a "simple block." All others 
are called "compound blocks" because they are internally comprised of other 
blocks. 

C. General Syntax 

[0058] All ODL keywords are case-insensitive. Thus, the keyword "field" will be 

interpreted to be the same as "FIELD." However, object names may be case- 
sensitive due to the fact that some high-level programming languages (such as C 
and C++) are case sensitive. Thus, the example object name "myobj" may not 
reference the same object as that of "MYOBJ." 

[0059] Scheme-style comments are supported. A comment consists of all 

characters between a semicolon and the following carriage return. 
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D. Object References 

[0060] There are two types of object references: a limited (normal) object 

reference (ObjectRef) and a complete object reference (ObjectCRef). 

[0061 ] The ObjectRef operator allows an object definition to reference another 

object definition. Only the public elements of the referenced object can be 
accessed. The parameters to ObjectRef may include any number of the 
properties of the referenced object. The ObjectRef operator resolves the 
reference and replaces itself with the object definition identified by the parameters. 
The following example references an object named "i Adder:" 
(ObjectRef (Block (Name M Adder))) 

[0062] The ObjectCRef operator works in the same manner as the ObjectRef 

operator except that it allows access to all elements of the referenced object, both 
public and private elements. This operator is normally only used with basis and 
extension elements. 

E. Type Specifier 

[0063] An object type specifier can specify either a built-in type, or an object 

definition. Built-in types are supported for building complex objects. A built-in 
type is specified using the Type operator. For instance, a built-in type may be 
specified by the following; 

(Type {igBol | iglnt | igFloat | igPointer}) 

[0064] For all other object types, the object definition is specified. Since most 

object definitions are defined in one place and referenced by their identifiers, the 
ObjectRef operator is usually used. However, if an object definition is used in 
only one place, it can appear "inline" (i.e., the entire body of the object may be 
used directly). A type specifier can state that the data exists either locally or 
remotely. A local object is one that is instantiated locally. A remote object is one 



that exists at another place (inside another object, for instance) and is referenced. 
The following example illustrates how an object named "Bar" is specified to be of 
type "iglnt:" 

(object Bar (type iglnt)) 
[0065] Objects having non-built-in types are specified using the definition of the 

object. Thus, the ObjcctRef operator may be used. For example, the following 
example illustrates how an object named "Bar2" is specified to be of the non built- 
in type "iAdder" using the ObjectRef operator: 

(object Bar2 (type(ObjectRef(Block(Name 'iAdder))))) 



F. Object References 



[0066] A package can either be a library or an application. The keyword "library" 

is used to denote libraries, and the keyword "application" is used to denote 
applications. The package ODL code must be the only top-level ODL element in 
the file, and there must be only one. For instance, you cannot define two ODL 
packages in the same file. 

[0067] All packages have names. The name of a package is specified as a normal 

property or as the first parameter of the package. The following example 
illustrates a package specification in which the name of the package is specified 
as a normal property : 

(library (name MyLib) ...) 
The following example illustrates a package specification in which the name of the 
package is specified as the first parameter of the package: 

(application MyApp ...) 

(application MyApp ...) 
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II. System in which the ODL is utilized 

[0068] A preferred embodiment of the system in which the present invention 

operates is now described with reference to the figures where like reference 
numbers indicate identical or functionally similar elements. The left most digit of 
each reference number corresponds to the figure in which the reference number 
is first used. While specific configurations and arrangements are discussed, it 
should be understood that this is done for illustrative purposes only. 

[0069] A person skilled in the relevant art will recognize that other configurations 

and arrangements can be used without departing from the spirit and scope of the 
invention. It will be apparent to a person skilled in the relevant art that this 
invention can also be employed in a variety of other applications. 

[0070] FIG. 1 is a diagram of an example embodiment of system 1 00, a system in 

which the ODL of the present invention is utilized. Game developer 1 10 writes 
C++ code 135 and ODL code 115. In the embodiment depicted in FIG. 1, ODL 
code 115 and C++ code 135 may be in separate files. ODL code 115 describes 
the structure and elements of the computer program written by developer 110. 
After the developer writes ODL code 115, code 115 is processed by IGEN 
compiler 120. IGEN compiler 120 produces code 125, which corresponds to 
ODL Code 115. In one embodiment, code 125 may be machine code. In 
another embodiment, Code 125 may be C++ human-readable code. Code 125 
then passes to C++ compiler 130. 

[0071] C++ code 135 is written by game developer 110 and also passes to C++ 

compiler 130. C++ compiler 130 compiles written C++ code 135 and combines 
C++ code 135 with Code 125. In one embodiment C++ compiler 130 also 
compiles code 1 25 (which is in the form of C++ human-readable code). Finally, 
object code 137, resulting from the compilation and combination, is executed on 
game platform 140. 

[0072] Referring to FIG. 2, an alternative embodiment of the present invention, 

C++ declarations 21 0a and ODL code 1 1 5 are developed together in a single file. 
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In such a case, ODL code 1 1 5 and C++ declarations 2 1 0a must be separated, as 
shown in FIG. 2. Header file 21 0 is written by game developer 1 1 0 and contains 
C++ declarations 210a and ODL code 115. Header file 210 is passed to I GEN 
module 215. More specifically , header file 2 1 0 is passed to separator 220, located 
within IGEN module 215. In one embodiment, separator 220, combiner 240, and 
IGEN compiler 120 may be contained in their own separate modules. 

[0073] Referring to the example embodiment in FIG. 2, Separator 220 extracts 

a copy of ODL code 115 from header file 210 written by the developer. 
Separator 220 then passes a copy of ODL code 115 to IGEN compiler 120. 
IGEN compiler 120 compiles ODL code 115 and generates code 125. In another 
embodiment IGEN compiler 120 is actually a translator and translates ODL code 
115 into human-readable C++ source code. After the compilation, IGEN compiler 
120 passes code 125 to combiner 240. Separator 220 passes the C++ 
declarations 210a (also represented in FIG. 2 by C++ User Preamble 222, C++ 
User Preobject 223, C++ User Members 224, C++ User Post-o]bject 225, and 
C++ User Postamble 226) to Combiner 240. 

[0074] Combiner 240 combines code 125 with ODL code 115 (written by the 

developer) and C++ declarations 222-226. The resulting product is a new C++ 
header file 250. Thus, New C++ header file 250 contains code 125, ODL code 
115, and declarations 210a. It should be noted that ODL code 115 is not 
discarded from the header file. Rather, a copy of ODL code 1 15 is maintained in 
the header file 250 as a means of allowing the developer to compare the contents 
of the header file 210 with the contents of the new header file 250. In another 
embodiment, ODL code 1 15 is discarded. 

[0075] FIG. 3 is a diagram of header file 2 1 0. Header file 2 1 0 contains ODL code 

312. ODL code 312 is written by Game developer 110. Header file 210 also 
contains C++ declaration sections 222-226. C++ declaration sections 222-226 are 
all user-edited code sections. All user-edited code must reside within these 
sections. Code inserted outside these sections will disappear during the build 
process. In another embodiment, if code is inserted outside the sections, an error 
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message will result, and the user will be allowed to rescue the code before header 
file 210 is overwritten. 

[0076] Header file 210 contains ODL code 115. All ODL code must reside within 

ODL definitions section 312. User Preamble section 222 contains high-level 
programming language code that must precede all other high-level programming 
language code in the file. For example, if the high-level programming language 
being used is C++, #include and #define directives would be present in User 
Preamble section 222. User Preobject section 223 contains high-level 
programming language code that must reside within the namespace but must 
precede all class declarations. 

[0077] Elements of the high-level programming language that are not supported 

by the ODL are placed in User Members section 224. For example , if the high- 
level programming language is C++, C++ function declarations would be placed 
in User Members section 224. 

[0078] User Postobject section 225 contains high-level programming language 

code that must reside within the namespace but must be located after all class 
declarations. 

[0079] User Postamble section 226 contains all high-level programming language 

code that must appear after all other high-level programming code in header file 
210. 

[0080] Referring to FIG. 4, a flowchart is shown representing the general 

operational flow, according to an embodiment of the system in which the present 
invention is utilized. More specifically, flowchart 400 depicts an example routine 
for processing header file 210. Routine 400 begins with step 402. In step 402, 
header file 2 1 0, containing C++ declarations 2 1 0a and ODL code 1 1 5, is read by 
IGEN module 215. In step 404, separator 220 copies ODL code 1 1 5 from header 
file 210 and passes the copied ODL code 1 15 to IGEN compiler 120. In step 
406, ODL code 1 1 5 is compiled to obtain code 125. In step 408, ODL code 1 25 
is combined with C++ code 135 (222-226 in FIG. 2) and ODL code 115, forming 
a new header file. 
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[0081 J FIG. 5 is a diagram representing two example code segments, ODL code 

5 1 0 and corresponding C++ code 520 of an embodiment of the present invention. 
ODL code 5 1 0 represents an object definition. The name of the object is "Dude." 
Object "Dude" contains two variables, x and y. Variable x is of type iglnt, and 
variable y is of type igFloat and is initially set to the real number 3.1 . 

[0082] Corresponding C++ code 520 is the result of 1GEN compilation of ODL 

code 510. Corresponding C++ code 520 contains a class named "Dude" with 
public access, and the variables x and y, just as ODL code 510 contains. 

[0083] While various embodiments of the present invention have been described 

above, it should be understood that they have been presented by way of example, 
and not limitation. It will be apparent to persons skilled in the relevant art(s) that 
various changes in form and detail can be made therein without departing from the 
spirit and scope of the invention. For instance, although the high-level 
programming language of C++ was used throughout the examples, it should be 
understood that the present invention may operate in conjunction with other 
programming languages. Thus, the present invention should not be limited by any 
of the above-described exemplary embodiments, but should be defined only in 
accordance with the following claims and their equivalents. 



